From 6b8d4098ca9a333cf4440e79f05e37a2b678bed1 Mon Sep 17 00:00:00 2001 From: Keir Fraser Date: Wed, 28 Oct 2009 10:55:17 +0000 Subject: [PATCH] Boot parameter definition adjustments Consolidate the various attributes into macros, and tell the compiler not to needlessly waste spec for aligning strings used at most once. Signed-off-by: Jan Beulich --- xen/include/xen/init.h | 38 ++++++++++++++++++++------------------ 1 file changed, 20 insertions(+), 18 deletions(-) diff --git a/xen/include/xen/init.h b/xen/include/xen/init.h index 4f9019afe0..fdfdb55835 100644 --- a/xen/include/xen/init.h +++ b/xen/include/xen/init.h @@ -92,30 +92,32 @@ struct kernel_param { extern struct kernel_param __setup_start, __setup_end; +#define __setup_str static __initdata __attribute__((__aligned__(1))) char +#define __kparam static __attribute_used__ __initsetup struct kernel_param + #define custom_param(_name, _var) \ - static char __setup_str_##_var[] __initdata = _name; \ - static struct kernel_param __setup_##_var __attribute_used__ \ - __initsetup = { __setup_str_##_var, OPT_CUSTOM, &_var, 0 } + __setup_str __setup_str_##_var[] = _name; \ + __kparam __setup_##_var = { __setup_str_##_var, OPT_CUSTOM, _var, 0 } #define boolean_param(_name, _var) \ - static char __setup_str_##_var[] __initdata = _name; \ - static struct kernel_param __setup_##_var __attribute_used__ \ - __initsetup = { __setup_str_##_var, OPT_BOOL, &_var, sizeof(_var) } + __setup_str __setup_str_##_var[] = _name; \ + __kparam __setup_##_var = \ + { __setup_str_##_var, OPT_BOOL, &_var, sizeof(_var) } #define invbool_param(_name, _var) \ - static char __setup_str_##_var[] __initdata = _name; \ - static struct kernel_param __setup_##_var __attribute_used__ \ - __initsetup = { __setup_str_##_var, OPT_INVBOOL, &_var, sizeof(_var) } + __setup_str __setup_str_##_var[] = _name; \ + __kparam __setup_##_var = \ + { __setup_str_##_var, OPT_INVBOOL, &_var, sizeof(_var) } #define integer_param(_name, _var) \ - static char __setup_str_##_var[] __initdata = _name; \ - static struct kernel_param __setup_##_var __attribute_used__ \ - __initsetup = { __setup_str_##_var, OPT_UINT, &_var, sizeof(_var) } + __setup_str __setup_str_##_var[] = _name; \ + __kparam __setup_##_var = \ + { __setup_str_##_var, OPT_UINT, &_var, sizeof(_var) } #define size_param(_name, _var) \ - static char __setup_str_##_var[] __initdata = _name; \ - static struct kernel_param __setup_##_var __attribute_used__ \ - __initsetup = { __setup_str_##_var, OPT_SIZE, &_var, sizeof(_var) } + __setup_str __setup_str_##_var[] = _name; \ + __kparam __setup_##_var = \ + { __setup_str_##_var, OPT_SIZE, &_var, sizeof(_var) } #define string_param(_name, _var) \ - static char __setup_str_##_var[] __initdata = _name; \ - static struct kernel_param __setup_##_var __attribute_used__ \ - __initsetup = { __setup_str_##_var, OPT_STR, &_var, sizeof(_var) } + __setup_str __setup_str_##_var[] = _name; \ + __kparam __setup_##_var = \ + { __setup_str_##_var, OPT_STR, &_var, sizeof(_var) } /* Make sure obsolete cmdline params don't break the build. */ #define __setup(_name, _fn) static void * __attribute_used__ _dummy_##_fn = _fn -- 2.30.2